**2.1** [5] <\$2.2> For the following C statement, what is the corresponding MIPS assembly code? Assume that the variables f, g, h, and i are given and could be considered 32-bit integers as declared in a C program. Use a minimal number of MIPS assembly instructions.

```
f = g + (h - 5);
```

```
addi f, h, -5 add f, f, g
```

**2.2** [5] <\$2.2> For the following MIPS assembly instructions above, what is a corresponding C statement?

```
add f, g, h add f, i, f
```

$$F = g + h + i$$

**2.3** [5] <\\$2.2, 2.3> For the following C statement, what is the corresponding MIPS assembly code? Assume that the variables f, g, h, i, and j are assigned to registers \$50, \$51, \$52, \$53, and \$54, respectively. Assume that the base address of the arrays A and B are in registers \$56 and \$57, respectively.

```
B[8] = A[i-j];
```

Sub \$t0, \$s3, \$s4 Add \$t0, \$s6, \$t0 Lw \$t1, 16(\$t0) Sw \$t1, 32(\$s7)

**2.4** [5] < $\S$ \$2.2, 2.3> For the MIPS assembly instructions below, what is the corresponding C statement? Assume that the variables f, g, h, i, and j are assigned to registers \$\$0, \$\$1, \$\$2, \$\$3, and \$\$4, respectively. Assume that the base address of the arrays A and B are in registers \$\$6 and \$\$7, respectively.

```
sll $t0, $s0, 2
                     \# $t0 = f * 4
add $t0, $s6, $t0
                     \# $t0 = &A[f]
sll $t1, $s1, 2
                     \# $t1 = g * 4
add $t1, $s7, $t1
                    \# $t1 = \&B[g]
                     \# f = A[f]
1 w
    $s0, 0($t0)
addi $t2, $t0, 4
     $t0. 0($t2)
add $t0. $t0. $s0
SW
    $t0, 0($t1)
```

B[g] = A[f+1] + A[f];

**2.5** [5] <§§2.2, 2.3> For the MIPS assembly instructions in Exercise 2.4, rewrite the assembly code to minimize the number if MIPS instructions (if possible) needed to carry out the same function.

**2.6** The table below shows 32-bit values of an array stored in memory.

| Address | Data |
|---------|------|
| 24      | 2    |
| 38      | 4    |
| 32      | 3    |
| 36      | 6    |
| 40      | 1    |

**2.6.1** [5] <§§2.2, 2.3> For the memory locations in the table above, write C code to sort the data from lowest to highest, placing the lowest value in the smallest memory location shown in the figure. Assume that the data shown represents the C variable called Array, which is an array of type int, and that the first number in the array shown is the first element in the array. Assume that this particular machine is a byte-addressable machine and a word consists of four bytes.

**2.6.2** [5] < § 2.2, 2.3> For the memory locations in the table above, write MIPS code to sort the data from lowest to highest, placing the lowest value in the smallest memory location. Use a minimum number of MIPS instructions. Assume the base address of Array is stored in register \$ s 6.

```
Lw $t0, 0($s6)
Lw $t1, 4($s6)
Lw $t2, 12($s6)
Lw $t3, 16($s6)
Sw $t3, 0($s6)
Sw $t0, 4($s6)
Sw $t1, 12($s6)
Sw $t2, 16($s6)
```

**2.7** [5] <\$2.3> Show how the value <code>0xabcdef12</code> would be arranged in memory of a little-endian and a big-endian machine. Assume the data is stored starting at address 0.

## Little endian:

Address 0: 12 Address 1: ef Address 2: cd Address 3: ab

## Big endian:

Address 0: ab Address 1: cd Address 2: ef Address 3: 12

**2.9** [5] <\$2.2, 2.3> Translate the following C code to MIPS. Assume that the variables f, g, h, i, and j are assigned to registers \$\$0, \$\$1, \$\$2, \$\$3, and \$\$4, respectively. Assume that the base address of the arrays A and B are in registers \$\$6 and \$\$7, respectively. Assume that the elements of the arrays A and B are 4-byte words:

```
B[8] = A[i] + A[j];
```

```
SII $t0, $s3, 2

Add $t0, $s6, $t0 # $t0 = &A[i]

Lw $t1, 0($t0) # t1 = A[i]

SII $t2, $s4, 2

Add $t2, $s6, $t2 # $t1 = &A[j]

Lw $t3, 0($t2) # t3 = A[j]

Add $t4, $t1, $t3 # t4 = A[i] + A[j]

Sw $t4, 32($s7) # B[8] = t4
```

**2.10** [5] <\$2.2, 2.3> Translate the following MIPS code to C. Assume that the variables f, g, h, i, and j are assigned to registers \$50, \$51, \$52, \$53, and \$54, respectively. Assume that the base address of the arrays A and B are in registers \$56 and \$57, respectively.

```
addi $t0, $s6, 4
add $t1, $s6, $0
sw $t1, 0($t0)
lw $t0, 0($t0)
add $s0, $t1, $t0
```

f = A[f] + A[f]

- **2.12** Assume that registers \$\$0 and \$\$1 hold the values  $0\times80000000$  and  $0\times00000000$ , respectively.
- **2.12.1** [5] <\$2.4> What is the value of \$t0 for the following assembly code? add \$t0, \$s0, \$s1

t0 = 0x50000000

**2.12.2** [5] <\$2.4> Is the result in \$t0 the desired result, or has there been overflow?

There has been overflow

**2.12.3** [5] <\\$2.4> For the contents of registers \\$0 and \\$1 as specified above, what is the value of \\$t0 for the following assembly code?

```
sub $t0, $s0, $s1
```

t0 = 0xB0000000

**2.12.4** [5] <\\$2.4> Is the result in \\$\tau0\$ the desired result, or has there been overflow?

No overflow

**2.12.5** [5] <\$2.4> For the contents of registers \$50 and \$51 as specified above, what is the value of \$t0 for the following assembly code?

```
add $t0, $s0, $s1 add $t0. $t0. $s0
```

t0 = D0000000

**2.12.6** [5] <\$2.4> Is the result in \$t0 the desired result, or has there been overflow?

## Overflow occurred

- **2.18** Assume that we would like to expand the MIPS register file to 128 registers and expand the instruction set to contain four times as many instructions.
- **2.18.1** [5] <\$2.5> How this would this affect the size of each of the bit fields in the R-type instructions?

Opcode would be 8 bits. Rs, rt, and rd would be 7 bits each

**2.18.2** [5] <\$2.5> How this would this affect the size of each of the bit fields in the I-type instructions?

Opcode would be 8 bits, rs, and rt would be 7 bits each

**2.18.3** [5] < § \$2.5, 2.10> How could each of the two proposed changes decrease the size of an MIPS assembly program? On the other hand, how could the proposed change increase the size of an MIPS assembly program?

Instructions would be bigger, meaning a program could possibly increase in size

**2.21** [5] <\$2.6> Provide a minimal set of MIPS instructions that may be used to implement the following pseudoinstruction:

```
not $t1. $t2 // bit-wise invert
```

**2.22** [5] <\$2.6> For the following C statement, write a minimal sequence of MIPS assembly instructions that does the identical operation. Assume \$t1 = A, \$t2 = B, and \$s1 is the base address of C.

```
A = C[0] \ll 4;
Lw $t3, 0($s1)
SII $t1, $t3, 4
```

2.26 Consider the following MIPS loop:

```
LOOP: slt $t2, $0, $t1
beq $t2, $0, DONE
subi $t1, $t1, 1
addi $s2, $s2, 2
j LOOP
```

**2.26.1** [5] < \$2.7> Assume that the register \$t1 is initialized to the value 10. What is the value in register \$s2 assuming \$s2 is initially zero?

```
$s2 = 20
```

**2.26.2** [5] <\$2.7> For each of the loops above, write the equivalent C code routine. Assume that the registers \$\$1, \$\$2, \$\$t1, and \$\$t2 are integers A, B, i, and temp, respectively.

**2.26.3** [5] <\$2.7> For the loops written in MIPS assembly above, assume that the register \$t1 is initialized to the value N. How many MIPS instructions are executed?

**2.29** [5] <\$2.7> Translate the following loop into C. Assume that the C-level integer i is held in register \$t1, \$s2 holds the C-level integer called result, and \$s0 holds the base address of the integer MemArray.

```
addi $t1, $0, $0
LOOP: lw $s1, 0($s0)
add $s2, $s2, $s1
addi $s0, $s0, 4
```

2.22 Exercises

17

```
addi $t1, $t1, 1
slti $t2, $t1, 100
bne $t2, $s0, L00P

Int i = 0;
While (i < 100) {
    Int value = MemArray[s0]
    Result += value;
    i++
}
```

**2.38** [5] <§2.9> Consider the following code:

```
1bu $t0, 0($t1)
sw $t0, 0($t2)
```

Assume that the register \$ $^{1}$  contains the address  $0 \times 1000 \, 0000$  and the register \$ $^{2}$  contains the address  $0 \times 1000 \, 0010$ . Note the MIPS architecture utilizes big-endian addressing. Assume that the data (in hexadecimal) at address  $0 \times 1000 \, 0000$  is:  $0 \times 11223344$ . What value is stored at the address pointed to by register \$ $^{2}$ ?

## 0x0000011

**2.47** Assume that for a given program 70% of the executed instructions are arithmetic, 10% are load/store, and 20% are branch.

**2.47.1** [5] <\$2.19> Given this instruction mix and the assumption that an arithmetic instruction requires 2 cycles, a load/store instruction takes 6 cycles, and a branch instruction takes 3 cycles, find the average CPI.

$$(0.7x2)+(0.10x6)+(0.2x3) = 2.6$$

**2.47.2** [5] < \$2.19> For a 25% improvement in performance, how many cycles, on average, may an arithmetic instruction take if load/store and branch instructions are not improved at all?

New cpi = 
$$0.75 \times 0.75 \times 0.75$$

**2.47.3** [5] <\$2.19> For a 50% improvement in performance, how many cycles, on average, may an arithmetic instruction take if load/store and branch instructions are not improved at all?

New cpi = 
$$0.5 \times 0.5 \times$$